$(function () {
    var laypage = layui.laypage;
    // layui自定义校验规则
    var form = layui.form
    // 定义美化时间的过滤器dataFormat
    template.defaults.imports.dataFormat = function (date) {
        const dt = new Date(date)

        var y = dt.getFullYear()
        var m = padZero(dt.getMonth() + 1)
        var d = padZero(dt.getDate())

        var hh = padZero(dt.getHours())
        var mm = padZero(dt.getMinutes())
        var ss = padZero(dt.getSeconds())

        return y + '-' + m + '-' + d + ' ' + hh + ':' + mm + ':' + ss
    }

    // 定义补零的函数
    function padZero(n) {
        return n > 9 ? n : '0' + n
    }
    // 定义一个查询的参数对象，将来请求数据的时候，
    var q = {
        pagenum: 1, // 页码值，默认请求第一页的数据
        pagesize: 2, // 每页显示几条数据，默认每页显示2条
        cate_id: '', // 文章分类的 Id
        state: '' // 文章的发布状态
    }
    initCate()//初始化文章分类表单
    initTable()//初始化文章列表 
    //初始化文章列表函数
    function initTable() {
        $.get('my/article/list', q, function (res) {
            if (res.status !== 0) {
                return layer.msg('获取文章列表失败！')
            }
            //模板引擎渲染页面数据
            var htmlStr = template('tpl-table', res)
            $('tbody').html(htmlStr)
            renderPage(res.total)
        })
    }
    //初始化文章分类表单函数
    function initCate() {
        $.get('my/article/cates', function (res) {
            if (res.status !== 0) {
                return layer.msg('获取分类数据失败！')
            }
            var htmlStr = template('tpl-cate', res)
            $('[name=cate_id]').html(htmlStr)
            //通过layui重新渲染表单的UI结构
            form.render()
        })
    }
    //监听表单的提交事件
    $('#form-search').on('click', function (e) {
        e.preventDefault()
        // 获取表单中选中项的值
        var cate_id = $('[name=cate_id]').val()
        var state = $('[name=state]').val()
        //修改查询对象q的数据
        q.cate_id = cate_id
        q.state = state
        // 根据最新的筛选条件，重新渲染表格的数据
        initTable()
    })
    //定义渲染分页的方法
    function renderPage(total) {
        // 调用 laypage.render() 方法来渲染分页的结构
        laypage.render({
            elem: 'pageBox', // 分页容器的 Id
            count: total, // 总数据条数
            limit: q.pagesize, // 每页显示几条数据
            curr: q.pagenum, // 设置默认被选中的分页
            layout: ['count', 'limit', 'prev', 'page', 'next', 'skip'],
            limits: [2, 3, 5, 10],// 每页展示多少条
            // 分页发生切换的时候，触发 jump 回调
            jump: function (obj, first) {
                q.pagenum = obj.curr
                q.pagesize = obj.limit
                if (!first) {
                    initTable()
                }
            }
        })

    }
    //通过事件代理给删除按钮绑定事件
    $('tbody').on('click', '#dele', function () {
        // 获取删除按钮的个数
        var len = $('#dele').length
        // 获取到文章的 id
        var id = $(this).attr('data-id')
        layer.confirm('确认删除?', { icon: 3, title: '提示' }, function (index) {
            $.get('my/article/delete/' + id, function (res) {
                if (res.status !== 0) {
                    return layer.msg('删除文章失败！')
                }
                layer.msg('删除文章成功！')
                layer.close(1)
                // 如果 len 的值等于1，证明删除完毕之后，页面上就没有任何数据了
                // 页码值最小必须是 1
                if (len === 1) {
                    q.pagenum = q.pagenum === 1 ? 1 : q.pagenum - 1
                }
                initTable()
            })
        })


    })
})